

PROGRAMAÇÃO DINÂMICA 


Q Cría-se uma matriz de distâncias com 

■ uma coluna por cada símbolo da sequência de saída 

■ uma linha por cada símbolo da sequência de entrada 

■ cada célula distanciai j,i] contém a distância entre os primeiros 
i caracteres da saída e os primeiros j caracteres da entrada 
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Q Cada célula pode ser calculada usando uma função das células que a 
rodeiam, sendo cada célula preenchida uma única vez 

Q O valor de cada célula é calculado como o mínimo de três passos 
alternativos: 
■ três possibilidades para chegar ao estado [j,i]: 
O por inserção de um carácter 
O por substituição de um carácter 
O por remoção de um carácter 



{ 



distância[j-1,i] + custoJnserção(Saídai) 
distância[j-1,i-1] + custo_Substituição(Saídaj, Entradaj) 
distância[j,i-1] + custo_Remoção(Entradaj) 



} 



íinesãd 




ALGORITMO 




k 



função número_mínimo_ediçoes( saída, entrada) devolve número_mínimo 

In *- comprimento (saída) 
'm «- comprimento (entrada) 



i cria a matriz distância [n+1, m+1] 

;distância[0,0] «- 

; para cada coluna j de 1 a n faz 

distância[j,0] <- distância [j -1,0] + custi 

para cada linha i de 1 a n faz 

distância[0,i] <- distância [0, i-1] + custi 

para cada coluna j de 1 a n faz 
para cada linha i de 1 a m faz 

distância [j,i] «- min(distância [ j-1, i] 

distância[j-l,i-l 
distância [j, i-1] 



linserçao ( saída j ) 
iremoção ( entrada i ) 



h custo_inserção(saídaj) , 

f custo_subs(saídaj ,entradai) 

f custo_remoção(entradai) ) 





EXEMPLO 
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